package org.layui.servlet;

import org.layui.dao.UserDao;
import org.layui.dao.impl.UserDaoImpl;
import org.layui.entity.User;
import org.layui.utils.JwtUtil;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

@WebServlet("/api/login")
public class LoginServlet extends BaseServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        // 第一：获取页面发送过来的商品信息（合法性验证[略]）
        String username = req.getParameter("username") ;
        String password = req.getParameter("password") ;

        // 第二：创建实体对象，并封装数据

        // 第三：创建DAO对象，实现数据添加操作
        UserDao userDao = new UserDaoImpl() ;
        User user = userDao.selectUser(username);

        // 第四：响应结果
        if(user!=null && password!=null && password.equals(user.getPassword().trim())) {
            // 定义一个Map对象，用于封装相关的令牌
            Map<String, Object> map = new HashMap<>();
            // 封装数据 -- 客户端浏览器只保留帐号名（用户ID）即可
            map.put("username", username);

            // 创建Token,设置有效时间为30分钟
            String token = JwtUtil.createToken(map, 30 * 60 * 1000);

            // 响应客户端
            print(resp, successJson(token));
            return;
        }

        print(resp, errorJson(401, "错误的帐号或密码"));
    }
}
